<template>
  <div class="columns py-6">
    <div class="column is-half is-offset-one-quarter">
      <el-card shadow="never">
        <div slot="header" class="has-text-centered has-text-weight-bold">
          用户登录
        </div>
        <div>
          <el-form
              v-loading="loading"
              :model="ruleForm"
              status-icon
              :rules="rules"
              ref="ruleForm"
              label-width="100px"
              class="demo-ruleForm"
          >
            <el-form-item label="账号" prop="name">
              <el-input v-model="ruleForm.name"></el-input>
            </el-form-item>

            <el-form-item label="密码" prop="pass">
              <el-input
                  type="password"
                  v-model="ruleForm.pass"
                  autocomplete="off"
              ></el-input>
            </el-form-item>

            <el-form-item label="记住" prop="delivery">
              <el-switch v-model="ruleForm.rememberMe"></el-switch>
            </el-form-item>

            <el-form-item>
              <el-button type="primary" @click="submitForm('ruleForm')"
              >提交
              </el-button
              >
              <el-button @click="resetForm('ruleForm')">重置</el-button>
            </el-form-item>
          </el-form>
        </div>
      </el-card>
    </div>
  </div>
</template>

<script>
import {login} from "@/api/auth/auth";
import {getInfo} from "@/api/user";

export default {
  name: "Login",
  data() {
    return {
      redirect: undefined,
      loading: false,
      ruleForm: {
        name: "",
        pass: "",
        rememberMe: true,
      },
      rules: {
        name: [
          {required: true, message: "请输入账号", trigger: "blur"},
          {
            min: 2,
            max: 15,
            message: "长度在 2 到 15 个字符",
            trigger: "blur",
          },
        ],
        pass: [
          {required: true, message: "请输入密码", trigger: "blur"},
          {
            min: 6,
            max: 20,
            message: "长度在 6 到 20 个字符",
            trigger: "blur",
          },
        ],
      },
    };
  },
  methods: {
    submitForm(formName) {
      this.$refs[formName].validate((valid) => {
        if (valid) {
          this.loading = true;
          let loginDTO = {
            'username': this.ruleForm.name,
            'password': this.ruleForm.pass
          }
          login(loginDTO).then(res => {
            if(res!==undefined){
              this.$message({
                message: "恭喜你，登录成功",
                type: "success",
                duration: 2000,
              });
              localStorage.setItem('Authorization', res.data.token);
              localStorage.setItem('username', this.ruleForm.name)

              setTimeout(()=>{
                this.loading=false;
                this.$router.go(0)
                // this.$router.push({ path: this.redirect || "/" });
              },0.1*10000)
            }else {
              this.loading=false
            }



            // //获取userInfo
            // getInfo(this.ruleForm.name).then(res=>{
            //   localStorage.setItem('userInfo',JSON.stringify(res.data))
            // })


            // this.$router.push({ path: this.redirect || "/" });
            // setTimeout(() => {
            //         this.loading = false;
            //         this.$router.push({ path: this.redirect || "/" });
            //       }, 0.1 * 1000);
          })


              .catch(() => {
                this.loading = false;
              })

          // this.$store
          //   .dispatch("user/login", this.ruleForm)
          //   .then(() => {
          //     this.$message({
          //       message: "恭喜你，登录成功",
          //       type: "success",
          //       duration: 2000,
          //     });
          //
          //     setTimeout(() => {
          //       this.loading = false;
          //       this.$router.push({ path: this.redirect || "/" });
          //     }, 0.1 * 1000);
          //   })
          //   .catch(() => {
          //     this.loading = false;
          //   });
        } else {
          return false;
        }
      });
    },
    resetForm(formName) {
      this.$refs[formName].resetFields();
    },
  },
};
</script>

<style scoped>
</style>